/* =========================
  THEME TOKENS (Dark default)
========================== */
:root{
  --radius-lg:14px; --radius-sm:8px; --radius-xl:24px;
  --shadow-soft:0 18px 40px rgba(0,0,0,.35);

  --accent:#38bdf8;
  --accent-2:#a855f7;
  --success:#22c55e;
  --danger:#f97373;

  --text:#e5e7eb;
  --muted:#9ca3af;

  --page-bg: radial-gradient(circle at top, #1f2937 0, #020617 55%);
  --shell-bg: linear-gradient(145deg, #020617 0, #020617 40%, #020617 100%);
  --shell-border: rgba(148,163,184,.25);

  --card-bg:
    radial-gradient(circle at top left, rgba(56,189,248,.08), transparent 45%),
    radial-gradient(circle at bottom right, rgba(168,85,247,.10), transparent 50%),
    #1f2937;
  --card-border: rgba(148,163,184,.30);
  --card-shadow: 0 10px 30px rgba(0,0,0,.35);

  --surface: rgba(15,23,42,.90);
  --surface-2: rgba(15,23,42,.98);
  --surface-border: rgba(148,163,184,.60);
  --surface-border-2: rgba(75,85,99,.90);

  --row-bg:
    radial-gradient(circle at top left, rgba(56,189,248,.13), transparent 55%),
    rgba(15,23,42,.95);
  --row-border: rgba(55,65,81,.90);

  --kpi-bg: linear-gradient(135deg, rgba(15,23,42,.90), rgba(15,23,42,.98));
  --kpi-border: rgba(148,163,184,.35);
  --kpi-shadow: 0 10px 26px rgba(0,0,0,.40);

  --chip-bg: rgba(15,23,42,.80);
  --tabs-bg: rgba(15,23,42,.85);
  --link-bg: rgba(15,23,42,.90);

  --input-bg: rgba(15,23,42,.98);
  --input-focus: rgba(15,23,42,1);

  --shell-glow:
    radial-gradient(circle at 0% 0%, rgba(56,189,248,.20), transparent 55%),
    radial-gradient(circle at 100% 0%, rgba(168,85,247,.16), transparent 60%);
  --shell-glow-opacity:.35;

  --border: rgba(148,163,184,.22);
}

/* Light mode swaps variables only */
body.light{
  --text:#020617;
  --muted:#4b5563;

  --page-bg: radial-gradient(circle at top, #e0f2fe 0, #f9fafb 55%);
  --shell-bg: linear-gradient(145deg, #ffffff 0, #e5f0ff 100%);
  --shell-border: rgba(148,163,184,.50);

  --card-bg:
    radial-gradient(circle at top left, rgba(59,130,246,.10), transparent 55%),
    #ffffff;
  --card-border: rgba(148,163,184,.60);
  --card-shadow: 0 12px 30px rgba(15,23,42,.12);

  --surface: rgba(255,255,255,.85);
  --surface-2: rgba(255,255,255,.92);
  --surface-border: rgba(148,163,184,.65);
  --surface-border-2: rgba(148,163,184,.65);

  --row-bg: rgba(255,255,255,.92);
  --row-border: rgba(148,163,184,.65);

  --kpi-bg: rgba(255,255,255,.92);
  --kpi-border: rgba(148,163,184,.65);
  --kpi-shadow: 0 10px 26px rgba(15,23,42,.10);

  --chip-bg: rgba(255,255,255,.85);
  --tabs-bg: rgba(255,255,255,.85);
  --link-bg: rgba(255,255,255,.85);

  --input-bg: rgba(255,255,255,.92);
  --input-focus: rgba(255,255,255,1);

  --shell-glow-opacity:.22;
}

*{ box-sizing:border-box; }

body{
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"SF Pro Text",sans-serif;
  background: var(--page-bg);
  color: var(--text);
  min-height:100vh;
  display:flex;
  justify-content:center;
  padding:clamp(8px,3vw,20px);
}

.app-shell{
  width:100%;
  max-width:1800px;
  background: var(--shell-bg);
  border-radius: var(--radius-xl);
  border:1px solid var(--shell-border);
  box-shadow: var(--shadow-soft);
  padding:20px 20px 16px;
  position:relative;
  overflow:hidden;
}
.app-shell::before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--shell-glow);
  opacity: var(--shell-glow-opacity);
  pointer-events:none;
}
.app-inner{ position:relative; z-index:1; }

header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:12px;
  gap:12px;
}

.title{ display:flex; flex-direction:column; gap:2px; }
.title h1{
  margin:0;
  font-size:clamp(1rem,1.2vw + .9rem,1.4rem);
  letter-spacing:.03em;
  display:flex;
  align-items:center;
  gap:10px;
}
.title small{ font-size:.78rem; color:var(--muted); }

.logo-img{
  width:48px;
  height:48px;
  border-radius:8px;
  object-fit:cover;
  box-shadow:0 0 24px rgba(56,189,248,.35);
}

.header-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
/* header: title left, actions right */
header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}

/* RIGHT stacked column */
.header-actions{
  margin-left:auto;
  display:flex;
  flex-direction:column;     /* stack */
  align-items:flex-end;       /* right align items */
  gap:10px;
  width:fit-content;          /* don't fill the whole header */
}

/* keep the tabs row right sized */
.header-actions .tabs{
  width:fit-content;
  max-width:100%;
  justify-content:flex-end;
}

/* backup/action rows */
.action-stack{
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-end;
  width:fit-content;
}

.action-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  width:fit-content;
}

/* prevent buttons from stretching wide */
.header-actions .btn,
.header-actions .pill-link{
  width:auto;
}
@media (max-width:900px){
  header{ flex-direction:column; }
  .header-actions{ align-self:flex-end; } /* keep it pinned to right */
}


.chip{
  font-size:.7rem;
  padding:3px 8px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  color:var(--muted);
  background: var(--chip-bg);
  backdrop-filter: blur(12px);
  display:inline-flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
}
.chip-dot{
  width:6px;height:6px;border-radius:999px;
  background:#4ade80;
  box-shadow:0 0 10px rgba(74,222,128,.9);
}

.tabs{
  display:inline-flex;
  border-radius:999px;
  padding:3px;
  background: var(--tabs-bg);
  border:1px solid var(--surface-border);
  backdrop-filter: blur(12px);
}
.tab-btn{
  border:none;
  background:transparent;
  color:var(--muted);
  padding:6px 14px;
  font-size:.8rem;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:all .2s ease;
}
.tab-btn.active{
  background: radial-gradient(circle at top left, var(--accent), #0ea5e9);
  color:#fff;
  box-shadow:0 0 20px rgba(56,189,248,.55);
}
.tab-btn .icon{ font-size:.9rem; }
.tabs a.tab-btn{ text-decoration:none; }

.pill-link{
  font-size:.7rem;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  color:var(--muted);
  background: var(--link-bg);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:all .18s ease;
  white-space:nowrap;
  cursor:pointer;
}
.pill-link:hover{ filter: brightness(1.03); color: var(--text); }

main{ margin-top:12px; }

#view-dashboard .grid{
  display:grid;
  gap:14px;
  grid-template-columns: minmax(240px, 420px) 1fr;
}


.card{
  background: var(--card-bg);
  border-radius: var(--radius-lg);
  border:1px solid var(--card-border);
  padding:14px 14px 16px;
  box-shadow: var(--card-shadow);
}

.card-header{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:8px;
  gap:10px;
}
.card-header h2{
  margin:0;
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.13em;
  color:var(--muted);
}
.card-header small{ font-size:.75rem; color:var(--muted); }

.kpi-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.kpi{
  background: var(--kpi-bg);
  border-radius:12px;
  padding:10px;
  border:1px solid var(--kpi-border);
  box-shadow: var(--kpi-shadow);
  position:relative;
  overflow:hidden;
}
.kpi::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at top right, rgba(56,189,248,.19), transparent 60%);
  opacity:.5;
  pointer-events:none;
}
body.light .kpi::before{ opacity:.28; }

.kpi-label{ font-size:.73rem; color:var(--muted); }
.kpi-value{ margin-top:4px; font-size:1.22rem; font-weight:700; }
.kpi-sub{ margin-top:2px; font-size:.7rem; color:var(--muted); }

.kpi-pill{
  position:absolute;
  right:8px; top:8px;
  font-size:.7rem;
  padding:3px 8px;
  border-radius:999px;
  background: var(--surface);
  border:1px solid var(--surface-border);
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  gap:4px;
}
.kpi-pill .dot{
  width:7px;height:7px;border-radius:999px;
  background: var(--success);
  box-shadow:0 0 8px rgba(34,197,94,.9);
}

.trip-list{
  max-height: min(80vh, 1100px);
  overflow: auto;
  padding-right: 4px;
  margin-top: 2px;
  scrollbar-width: thin;
}

/* Big screens: show even more */
@media (min-width: 1100px){
  .trip-list{
    max-height: min(78vh, 980px);
  }
}


.trip-row{
  border-radius:10px;
  padding:8px 9px;
  border:1px solid var(--row-border);
  background: var(--row-bg);
  margin-bottom:7px;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:10px;
  box-shadow: 0 10px 26px rgba(15,23,42,.08);
}
.trip-main{ flex:1; }
.trip-name{ font-size:.9rem; font-weight:600; margin-bottom:2px; }
.trip-meta{
  font-size:.75rem;
  color:var(--muted);
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.badge{
  padding:2px 6px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  font-size:.72rem;
  background: var(--surface);
  color: var(--muted);
}

#view-ports .trip-list{ max-height:none; overflow:visible; padding-right:0; }
#view-ports .trip-row{ padding:6px 8px; margin-bottom:6px; }
#view-ports .trip-name{ font-size:.88rem; }
#view-ports .trip-meta{ gap:6px; font-size:.72rem; }

.trip-actions{ display:flex; flex-direction:column; gap:4px; }

.btn{
  border:none;
  border-radius:999px;
  padding:5px 10px;
  font-size:.7rem;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  background: var(--surface);
  color: var(--muted);
  border:1px solid var(--surface-border);
  transition:all .18s ease;
  text-decoration:none;
  white-space:nowrap;
}
.btn:hover{ filter: brightness(1.03); color: var(--text); }

.btn-primary{
  background: linear-gradient(135deg, #0ea5e9, var(--accent));
  border-color:transparent;
  color:#fff;
  box-shadow:0 0 16px rgba(56,189,248,.55);
}
.btn-primary:hover{ filter: brightness(1.05); }

.btn-danger{
  border-color: rgba(248,113,113,.70);
  color: #fecaca;
}
body.light .btn-danger{ color:#b91c1c; border-color: rgba(239,68,68,.55); }
.btn-danger:hover{ background: rgba(239,68,68,.10); }

form{ display:flex; flex-direction:column; gap:8px; margin-top:4px; }
.field-row{ display:flex; gap:8px; flex-wrap:wrap; }
.field{ display:flex; flex-direction:column; gap:3px; flex:1; }
.field-row .field{ flex:1 1 160px; }

label{ font-size:.7rem; color:var(--muted); }

input, textarea{
  border-radius: var(--radius-sm);
  border:1px solid var(--surface-border-2);
  padding:5px 8px;
  background: var(--input-bg);
  color: var(--text);
  font-size:.78rem;
  font-family:inherit;
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
input:focus, textarea:focus{
  border-color: var(--accent);
  box-shadow:0 0 0 1px rgba(56,189,248,.55);
  background: var(--input-focus);
}
textarea{ resize:vertical; min-height:60px; }

.form-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:2px;
  gap:8px;
  flex-wrap:wrap;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:.7rem;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  background: var(--surface);
  color: var(--muted);
}
.pill-dot{ width:6px;height:6px;border-radius:999px; }
.pill-dot.green{ background:#22c55e; }
.pill-dot.orange{ background:#fb923c; }

.ports-list{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:6px; }
.port-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  font-size:.7rem;
  background: var(--surface);
  color: var(--muted);
}
.port-pill button{
  border:none;
  background:transparent;
  cursor:pointer;
  padding:0;
  font-size:.7rem;
  color: #ef4444;
}

.port-hide-toggle{
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-left:6px;
  font-size:.68rem;
  color: var(--muted);
  user-select:none;
}
.port-hide-toggle input{ transform: translateY(1px); cursor:pointer; }

.help-text{ font-size:.68rem; color:var(--muted); margin-top:2px; }
.empty{ font-size:.78rem; color:var(--muted); margin-top:6px; }

/* =========================
  LOGIN MODAL
========================== */
.modal-backdrop{
  position:fixed; inset:0; z-index:999999;
  background: rgba(0,0,0,.55);
  display:none;
  align-items:center;
  justify-content:center;
  padding:16px;
}
.modal{
  width:min(520px, 100%);
  background: var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:18px;
  box-shadow: var(--shadow-soft);
  padding:14px;
}
.modal h3{
  margin:0 0 6px;
  font-size:1rem;
  letter-spacing:.02em;
}
.modal p{
  margin:0 0 10px;
  color: var(--muted);
  font-size:.82rem;
  line-height:1.35;
}
.modal .row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  margin-top:10px;
}
.username-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.7rem;
  padding:3px 10px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  color:var(--muted);
  background: var(--chip-bg);
  white-space:nowrap;
}

/* Dashboard trip notes timer */
.trip-inline-timer{ margin-top:6px; }
.trip-inline-timer .countdown{
  font-size:1.05rem;
  font-weight:650;
  margin-top:2px;
}
.trip-inline-timer .count-label{
  font-size:.78rem;
  color:var(--muted);
  margin-top:2px;
  margin-bottom:10px;
}

/* Site footer */
.site-footer{
  margin-top: 28px;
  padding: 14px 10px;
  text-align: center;
  font-size: 13px;
  color: var(--muted, #9ca3af);
  border-top: 1px solid var(--border, rgba(148,163,184,.22));
}
.site-footer a{
  color: var(--accent, #38bdf8);
  text-decoration: none;
  font-weight: 500;
}
.site-footer a:hover{
  text-decoration: underline;
}
.footer-sep{
  margin: 0 8px;
  opacity: 0.6;
}

@media (max-width:900px){
  body{ padding:12px; }
  .app-shell{ padding:14px 14px 12px; border-radius:18px; }
  header{ flex-direction:column; align-items:flex-start; gap:8px; }
  .header-actions{ width:100%; justify-content:space-between; }
  
}
@media (max-width:600px){
  body{ padding:10px; }
  .app-shell{ padding:10px 10px 12px; border-radius:14px; }
  .title h1{ font-size:clamp(.95rem,3.5vw,1.2rem); }
  .title small{ font-size:.7rem; }
  .chip{ width:100%; justify-content:center; }
  .tabs{ width:100%; justify-content:space-between; }
  .tab-btn{ flex:1; justify-content:center; padding:6px 8px; font-size:.75rem; }
  .grid{ gap:10px; }
  .card-header{ flex-direction:column; align-items:flex-start; gap:4px; }
  .trip-row{ flex-direction:column; }
  .trip-actions{ flex-direction:row; width:100%; flex-wrap:wrap; }
  .trip-actions .btn{ flex:1 1 120px; }
  input, textarea{ font-size:.76rem; }
  .field-row{ flex-direction:column; }
}


/* Excursion notes: show first 2 lines with expand */
.exc-notes-clamp{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.exc-notes-full{ }
.exc-notes-toggle{
  margin-top:6px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  background: var(--surface);
  font-size:.72rem;
  color:var(--accent);
  cursor:pointer;
  user-select:none;
}


/* Wider layout for Trips tab (All Trips + Add Trip cards) */
#view-trips .grid{
  grid-template-columns: 1.25fr 1fr;
}
@media (max-width: 912px){
  #view-trips .grid{ grid-template-columns: 1fr; }
}

.exc-notes{ white-space: pre-wrap; }


/* === Trip Planner (embedded) styling === */

.trip-planner{ margin-top:10px; }
.trip-planner details{
  border:1px solid var(--border);
  border-radius:16px;
  background: var(--surface);
  padding:10px;
}
.trip-planner summary{
  cursor:pointer;
  font-weight:750;
  letter-spacing:.01em;
  list-style:none;
  padding:10px 12px;
  border-radius:14px;
  background:
    radial-gradient(circle at top left, rgba(56,189,248,.12), transparent 55%),
    radial-gradient(circle at top right, rgba(168,85,247,.12), transparent 60%),
    var(--surface-2);
  border:1px solid rgba(148,163,184,.18);
  user-select:none;
}
.trip-planner summary::-webkit-details-marker{ display:none; }
.trip-planner details[open] summary{ margin-bottom:10px; }



/* Trip Planner: Excursions narrow (right), Daily Agenda wide (left) */
.trip-planner .planner-sections{
  grid-template-columns: 1fr minmax(240px, 340px) !important;
}

@media (max-width:980px){
  .planner-sections{ grid-template-columns:1fr; }
}

@media (max-width:980px){
  .planner-sections{ grid-template-columns:1fr; }
}

.planner-section{
  border:1px solid rgba(148,163,184,.18);
  border-radius:16px;
  background:
    radial-gradient(circle at top left, rgba(56,189,248,.10), transparent 55%),
    var(--surface-2);
  padding:12px;
}
.planner-section h4{
  margin:0 0 10px;
  font-size:.8rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}

.planner-list{ display:flex; flex-direction:column; gap:8px; }

.planner-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px;
  border-radius:14px;
  border:1px solid rgba(148,163,184,.18);
  background: rgba(15,23,42,.60);
}
body.light .planner-item{ background: rgba(255,255,255,.75); }

.planner-check{ transform: translateY(2px); cursor:pointer; }
.planner-text{ flex:1; min-width:0; }
.planner-title{
  font-weight:750;
  font-size:.92rem;
  margin:0;
  line-height:1.2;
}
.planner-title a{
  color:var(--accent);
  text-decoration:underline;
  text-underline-offset:3px;
}
.planner-sub{
  margin-top:4px;
  color:var(--text);
  opacity:.92;
  font-size:.82rem;
  line-height:1.25;
  word-break:break-word;
}
.planner-sub.muted{ color:var(--muted); opacity:1; }

.planner-actions{ display:flex; gap:8px; align-items:flex-start; }
.planner-actions .btn{ padding:6px 10px; }
.planner-actions .btn.btn-danger{ padding:6px 10px; }

.planner-add{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  align-items:center;
}
.planner-add input{ width:100%; }
.planner-add .btn{ justify-self:start; }
@media (max-width:600px){
  .planner-add{ grid-template-columns:1fr; }
  .planner-add .btn{ width:100%; }
}

.planner-mini-note{
  margin-top:10px;
  font-size:.72rem;
  color:var(--muted);
}

/* Daily Agenda columns */
.agenda-days{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:10px;
  margin-top:4px;
}
.agenda-day{
  border:1px solid rgba(148,163,184,.18);
  border-radius:16px;
  background: rgba(15,23,42,.55);
  padding:10px;
}
body.light .agenda-day{ background: rgba(255,255,255,.75); }
.agenda-day h5{
  margin:0 0 8px;
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.10em;
  text-transform:uppercase;
}


/* Agenda day card (FIX: mobile box missing) */
.agenda-day-card{
  border:1px solid rgba(148,163,184,.18);
  border-radius:16px;
  background: rgba(15,23,42,.55);
  padding:10px;
}

body.light .agenda-day-card{ background: rgba(255,255,255,.75); }

.agenda-day-title{
  margin:0 0 8px;
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.10em;
  text-transform:uppercase;
  font-weight:750;
}

.agenda-drop{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-height:40px;
  padding:8px;
  border-radius:12px;
  border:1px dashed rgba(148,163,184,.25);
  background: rgba(2,6,23,.10);
}
body.light .agenda-drop{ background: rgba(2,6,23,.04); }

.agenda-drag{
  cursor:grab;
  font-size:18px;
  line-height:1;
  opacity:.8;
  margin-right:4px;
  user-select:none;
}


/* =========================
   Daily Agenda - flat list styling
========================= */
.agenda-drop-flat{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:12px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:rgba(2,6,23,.35);
}

.ag-pill{
  display:inline-flex;
  align-items:center;
  padding:2px 10px;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.28);
  background:rgba(15,23,42,.55);
  font-weight:700;
  letter-spacing:.2px;
}

.ag-time{
  opacity:.9;
  font-weight:600;
}

.planner-item.agenda-item .planner-sub{
  margin-top:6px;
}

.planner-item.agenda-item .planner-actions{
  display:flex;
  gap:8px;
  align-items:center;
}

/* =========================
   Daily Agenda inline edit mode
========================= */
.agenda-item .ag-editform{ display:none; margin-top:10px; }
.agenda-item.is-editing .ag-view{ display:none; }
.agenda-item.is-editing .ag-editform{ display:block; }
.agenda-item.is-editing .ag-actions{ display:none; }

.ag-editform .ag-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:10px;
}
@media (max-width:520px){
  .ag-editform .ag-grid{ grid-template-columns:1fr; }
}

.ag-editform textarea.ag-in-notes{
  margin-top:10px;
  min-height:64px;
  resize:vertical;
}

.ag-edit-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:10px;
}



/* =========================
  PLANNER POLISH
========================== */
.exc-notes-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  margin-top:6px;
  border-radius:999px;
  border:1px solid var(--surface-border);
  background: var(--surface);
  color: var(--muted);
  font-size:.72rem;
  cursor:pointer;
  user-select:none;
}
.exc-notes-toggle:hover{ color: var(--text); filter: brightness(1.03); }

.agenda-item{ position:relative; }
.agenda-item .planner-actions{ display:flex; gap:6px; align-items:center; }

.ag-editform{
  display:none;
  width:100%;
  margin-top:8px;
  padding-top:8px;
  border-top:1px solid var(--surface-border);
}
.agenda-item.is-editing .ag-view{ display:none; }
.agenda-item.is-editing .ag-editform{ display:block; }

.ag-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 2fr 1fr;
  gap:8px;
  margin-bottom:8px;
}
@media (max-width: 680px){
  .ag-grid{ grid-template-columns: 1fr 1fr; }
}
.ag-editform input, .ag-editform textarea{
  width:100%;
  border-radius:12px;
  padding:8px 10px;
  border:1px solid var(--surface-border);
  background: rgba(255,255,255,.03);
  color: var(--text);
  outline:none;
}
body.light .ag-editform input, body.light .ag-editform textarea{
  background: rgba(0,0,0,.03);
  color: var(--text);
}
.ag-editform textarea{ min-height:64px; resize:vertical; }



/* Agenda inline edit buttons */
.icon-btn{
  width:36px;
  height:36px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid rgba(148,163,184,.22);
  background: rgba(2,6,23,.28);
  color: var(--text);
  cursor:pointer;
  flex:0 0 auto;
}
.icon-btn:hover{ border-color: rgba(56,189,248,.45); }
.icon-btn:active{ transform: translateY(1px); }
body.light .icon-btn{ background: rgba(255,255,255,.65); }

.agenda-edit-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:8px;
  width:100%;
}
.agenda-edit-grid input{
  width:100%;
  min-width:0;
}
@media (max-width: 560px){
  .agenda-edit-grid{ grid-template-columns: 1fr; }

.exc-edit-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:8px;
  width:100%;
}
.exc-edit-grid input{
  width:100%;
  min-width:0;
}
@media (max-width: 560px){
  .exc-edit-grid{ grid-template-columns: 1fr; }
}
}
/* =========================
   MOBILE: SINGLE COLUMN
========================== */
@media (max-width: 768px) {
  /* Dashboard + Trips grids */
  #view-dashboard .grid,
  #view-trips .grid {
    grid-template-columns: 1fr;
  }
}


/* =========================
   Daily Agenda: 2 columns on desktop
   (keeps 1 column on smaller screens)
========================== */
@media (min-width: 1000px){
  .trip-planner .agenda-days{
    grid-template-columns: repeat(2, minmax(260px, 1fr));
  }
}
@media (max-width: 999px){
  .trip-planner .agenda-days{
    grid-template-columns: 1fr;
  }
}

/* Trip planner + deck buttons */
.trip-planner-buttons{
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}

.trip-planner-details > summary,
.trip-planner-deck-btn{
  list-style: none;
  cursor: pointer;
  border-radius: 12px;
  padding: 10px 14px;
  border: 1px solid var(--surface-border);
  background: linear-gradient(135deg, rgba(56,189,248,.12), rgba(168,85,247,.12));
  color: var(--text);
  font-weight: 650;
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  transition: all .18s ease;
  text-decoration: none;
  display: block;
}

.trip-planner-details > summary:hover,
.trip-planner-deck-btn:hover{
  filter: brightness(1.08);
}
/* Make Trip Planner and Deck Plan buttons EXACT same size */
.trip-planner-details > summary,
.trip-planner-deck-btn{
  height: 44px;                 /* force same height */
  display: flex;               /* align icon + text same way */
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  box-sizing: border-box;
}

/* Remove default marker spacing differences */
.trip-planner-details > summary::-webkit-details-marker{
  display: none;
}
.trip-planner-details > summary::marker{
  content: "";
}
/* KPI cards: align number under title nicely */
.kpi,
.kpi-card{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* Make sure the big number block aligns left */
.kpi .kpi-value,
.kpi-card .kpi-value,
.kpi .value,
.kpi-card .value{
  align-self: flex-start;
}


/* Login modal: 3 buttons (Local / Demo / Continue) wrap nicely */
.login-actions{ flex-wrap:wrap; }
.login-actions .btn{ flex:1 1 140px; }
